## **HDL Verifier™**

**Getting Started Guide** 



# MATLAB® & SIMULINK®



### **How to Contact MathWorks**



Latest news: www.mathworks.com

Sales and services: www.mathworks.com/sales\_and\_services

User community: www.mathworks.com/matlabcentral

Technical support: www.mathworks.com/support/contact\_us

T

Phone: 508-647-7000



The MathWorks, Inc. 1 Apple Hill Drive Natick, MA 01760-2098

HDL Verifier<sup>™</sup> Getting Started Guide

© COPYRIGHT 2003-2019 by The MathWorks, Inc.

The software described in this document is furnished under a license agreement. The software may be used or copied only under the terms of the license agreement. No part of this manual may be photocopied or reproduced in any form without prior written consent from The MathWorks, Inc.

FEDERAL ACQUISITION: This provision applies to all acquisitions of the Program and Documentation by, for, or through the federal government of the United States. By accepting delivery of the Program or Documentation, the government hereby agrees that this software or documentation qualifies as commercial computer software or commercial computer software documentation as such terms are used or defined in FAR 12.212, DFARS Part 227.72, and DFARS 252.227-7014. Accordingly, the terms and conditions of this Agreement and only those rights specified in this Agreement, shall pertain to and govern the use, modification, reproduction, release, performance, display, and disclosure of the Program and Documentation by the federal government (or other entity acquiring for or through the federal government) and shall supersede any conflicting contractual terms or conditions. If this License fails to meet the government's needs or is inconsistent in any respect with federal procurement law, the government agrees to return the Program and Documentation, unused, to The MathWorks, Inc.

#### **Trademarks**

MATLAB and Simulink are registered trademarks of The MathWorks, Inc. See www.mathworks.com/trademarks for a list of additional trademarks. Other product or brand names may be trademarks or registered trademarks of their respective holders.

#### **Patents**

MathWorks products are protected by one or more U.S. patents. Please see www.mathworks.com/patents for more information.

### **Revision History**

| ne only | New for Version 1 (Release 13SP1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ne only | Revised for Version 1.1 (Release 13SP1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ne only | Revised for Version 1.1.1 (Release 14)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| ne only | Revised for Version 1.2 (Release 14SP1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ne only | Revised for Version 1.3 (Release 14SP1+)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| ne only | Revised for Version 1.3.1 (Release 14SP2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| ne only | Revised for Version 1.4 (Release 14SP3)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ne only | Revised for Version 2.0 (Release 2006a)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ne only | Revised for Version 2.1 (Release 2006b)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ne only | Revised for Version 2.2 (Release 2007a)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ne only | Revised for Version 2.3 (Release 2007b)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ne only | Revised for Version 2.4 (Release 2008a)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ne only | Revised for Version 2.5 (Release 2008b)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ne only | Revised for Version 2.6 (Release 2009a)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ne only | Revised for Version 3.0 (Release 2009b)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ne only | Revised for Version 3.1 (Release 2010a)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|         | Revised for Version 3.2 (Release 2010b)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ne only | Revised for Version 3.3 (Release 2011a)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ne only | Revised for Version 3.4 (Release 2011b)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 5       | Revised for Version 4.0 (Release 2012a)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ne only | Revised for Version 4.1 (Release 2012b)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ne only | Revised for Version 4.2 (Release 2013a)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ne only | Revised for Version 4.3 (Release 2013b)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ne only | Revised for Version 4.4 (Release 2014a)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ne only | Revised for Version 4.5 (Release 2014b)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ne only | Revised for Version 4.6 (Release 2015a)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ne only | Revised for Version 4.7 (Release 2015b)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ne only | Revised for Version 5.0 (Release 2016a)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ne only | Revised for Version 5.1 (Release 2016b)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ne only | Revised for Version 5.2 (Release 2017a)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|         | Revised for Version 5.3 (Release 2017b)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ne only | Revised for Version 5.4 (Release 2018a)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|         | Revised for Version 5.5 (Release 2018b)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ne only | Revised for Version 5.6 (Release 2019a)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| •       | , , ,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|         | ne only |

# Contents

|      | Introduc                                          | tio    |
|------|---------------------------------------------------|--------|
| HDL  | Verifier Product Description                      | 1<br>1 |
|      | About HDL Ver                                     | ifi    |
| HDI  | Cosimulation                                      | 2      |
|      | HDL Cosimulation with MATLAB or Simulink          | 2      |
|      | Communications for HDL Cosimulation               | :      |
|      | Hardware Description Language (HDL) Support       |        |
|      | HDL Cosimulation Workflows                        |        |
|      | Product Features and Platform Support             | ,      |
| FPG  | A Verification                                    |        |
|      | FPGA Verification with HDL Verifier and HDL Coder |        |
|      | Product Features and Platform Support             |        |
| TLM  | Component Generation                              | 2      |
|      |                                                   | 2      |
|      | Typical Users and Applications                    | 2      |
|      | Product Feature and Platform Support              | 2      |
| Syst | emVerilog DPI Component Generation                | 2      |
|      | Interface                                         | 2      |
|      | 1110011400                                        |        |

### **Third-Party Product Requirements**

|   | ٦. | 2 |   |
|---|----|---|---|
|   | •  |   | ١ |
| 1 |    | - | ١ |

| Supported EDA Tools and Hardware      | 3-2  |
|---------------------------------------|------|
| Cosimulation Requirements             | 3-2  |
| FPGA Verification Requirements        |      |
| DPI Component Generation Requirements |      |
| TLM Generation Requirements           | 3-13 |

# Introduction

### **HDL Verifier Product Description**

### Verify VHDL and Verilog using HDL simulators and FPGA-in-the-loop test benches

HDL Verifier automatically generates test benches for Verilog® and VHDL® design verification. You can use MATLAB® or Simulink® to directly stimulate your design and then analyze its response using HDL cosimulation or FPGA-in-the-loop with Xilinx®, Intel®, and Microsemi® FPGA boards. This approach eliminates the need to author standalone Verilog or VHDL test benches.

HDL Verifier also generates components that reuse MATLAB and Simulink models natively in simulators from Cadence®, Mentor Graphics®, and Synopsys®. These components can be used as verification checker models or as stimuli in more complex test-bench environments such as those that use the Universal Verification Methodology (UVM).

### **Key Features**

- Cosimulation with Cadence Incisive® and Xcelium  $^{\tiny TM}$  , as well as Mentor Graphics ModelSim® and Questa®
- FPGA-in-the-loop verification using Xilinx, Intel, and Microsemi FPGA boards
- SystemVerilog DPI component generation from MATLAB functions and Simulink blocks
- Generation of IEEE® 1666 SystemC TLM 2.0 compatible transaction-level models
- Automated verification workflow with HDL Coder™

## **About HDL Verifier**

- "HDL Cosimulation" on page 2-2
- "FPGA Verification" on page 2-8
- "TLM Component Generation" on page 2-10
- "SystemVerilog DPI Component Generation" on page 2-13
- "HDL Verifier Supported Hardware" on page 2-15

### **HDL Cosimulation**

### In this section...

"HDL Cosimulation with MATLAB or Simulink" on page 2-2

"Communications for HDL Cosimulation" on page 2-6

"Hardware Description Language (HDL) Support" on page 2-6

"HDL Cosimulation Workflows" on page 2-7

"Product Features and Platform Support" on page 2-7

### **HDL Cosimulation with MATLAB or Simulink**

The HDL Verifier software consists of MATLAB functions, a MATLAB System object<sup>™</sup>, and a library of Simulink blocks, all of which establish communication links between the HDL simulator and MATLAB or Simulink.

HDL Verifier software streamlines FPGA and ASIC development by integrating tools available for the following processes:

- 1 Developing specifications for hardware design reference models
- 2 Implementing a hardware design in HDL based on a reference model
- **3** Verifying the design against the reference design

The following figure shows how the HDL simulator and MathWorks $^{\text{@}}$  products fit into this hardware design scenario.



As the figure shows, HDL Verifier software connects tools that traditionally have been used discretely to perform specific steps in the design process. By connecting these tools, the link simplifies verification by allowing you to cosimulate the implementation and original specification directly. This cosimulation results in significant time savings and the elimination of errors inherent to manual comparison and inspection.

In addition to the preceding design scenario, HDL Verifier software enables you to work with tools in the following ways:

- Use MATLAB or Simulink to create test signals and software test benches for HDL code
- Use MATLAB or Simulink to provide a behavioral model for an HDL simulation
- Use MATLAB analysis and visualization capabilities for real-time insight into an HDL implementation
- Use Simulink to translate legacy HDL descriptions into system-level views

**Note** You can cosimulate a module using SystemVerilog, SystemC or both with MATLAB or Simulink using the HDL Verifier software. Write simple wrappers around the SystemC and make sure that the SystemVerilog cosimulation connections are to ports or signals of data types supported by the link cosimulation interface.

More discussion on how cosimulation works can be found in the following sections:

- "Linking with MATLAB and the HDL Simulator" on page 2-3
- "Linking with Simulink and the HDL Simulator" on page 2-5
- "The HDL Cosimulation Wizard" on page 2-6

### Linking with MATLAB and the HDL Simulator

When linked with MATLAB, the HDL simulator functions as the client, as the following figure shows.



In this scenario, a MATLAB server function waits for service requests that it receives from an HDL simulator session. After receiving a request, the server establishes a communication link and invokes a specified MATLAB function that computes data for, verifies, or visualizes the HDL module (coded in VHDL or Verilog) that is under simulation in the HDL simulator.

After the server is running, you can start and configure the HDL simulator or use with MATLAB with the supplied HDL Verifier function:

- nclaunch (Incisive®)
- vsim (ModelSim)

The following figure shows how a MATLAB test bench function wraps around and communicates with the HDL simulator during a test bench simulation session.



The following figure shows how a MATLAB component function is wrapped around by and communicates with the HDL simulator during a component simulation session.



When you begin a specific test bench or component session, you specify parameters that identify the following information:

- The mode and, if applicable, TCP/IP data for connecting to a MATLAB server
- The MATLAB function that is associated with and executes on behalf of the HDL instance
- Timing specifications and other control data that specifies when the module's MATLAB function is to be called

### Linking with Simulink and the HDL Simulator

When linked with Simulink, the HDL simulator functions as the server, as shown in the following figure.



In this case, the HDL simulator responds to simulation requests it receives from cosimulation blocks in a Simulink model. You begin a cosimulation session from Simulink. After a session is started, you can use Simulink and the HDL simulator to monitor simulation progress and results. For example, you might add signals to an HDL simulator Wave window to monitor simulation timing diagrams.

Using the Block Parameters dialog box for an HDL Cosimulation block, you can configure the following:

- Block input and output ports that correspond to signals (including internal signals) of an HDL module. You can specify sample times and fixed-point data types for individual block output ports if desired.
- Type of communication and communication settings used for exchanging data between the simulation tools.
- Rising-edge or falling-edge clocks to apply to your module. You can individually specify the period of each clock.
- Tcl commands to run before and after the simulation.

HDL Verifier software equips the HDL simulator with a set of customized functions. For ModelSim, when you use the function <code>vsimulink</code>, you execute the HDL simulator with an instance of an HDL module for cosimulation with Simulink. After the module is loaded, you can start the cosimulation session from Simulink. Incisive users can perform the same operations with the function <code>hdlsimulink</code>.

HDL Verifier software also includes a block for generating value change dump (VCD) files. You can use VCD files generated with this block to perform the following tasks:

- View Simulink simulation waveforms in your HDL simulation environment
- Compare results of multiple simulation runs, using the same or different simulation environments
- Use as input to post-simulation analysis tools

#### The HDL Cosimulation Wizard

HDL Verifier contains the Cosimulation Wizard feature, which uses existing HDL code to create a customized MATLAB function (test bench or component), MATLAB System object, or Simulink HDL Cosimulation block. For more information, see "Prepare to Import HDL Code for Cosimulation".

### Communications for HDL Cosimulation

The mode of communication that you use for a link between the HDL simulator and MATLAB or Simulink depends on whether your application runs in a local, single-system configuration or in a network configuration. If these products and MathWorks products can run locally on the same system and your application requires only one communication channel, you have the option of choosing between shared memory and TCP/IP socket communication. Shared memory communication provides optimal performance and is the default mode of communication.

TCP/IP socket mode is more versatile. You can use it for single-system and network configurations. This option offers the greatest scalability. For more on TCP/IP socket communication, see "TCP/IP Socket Ports".

### Hardware Description Language (HDL) Support

All HDL Verifier MATLAB functions and the HDL Cosimulation block offer the same language-transparent feature set for both Verilog and VHDL models.

HDL Verifier software also supports mixed-language HDL models (models with both Verilog and VHDL components), allowing you to cosimulate VHDL and Verilog signals simultaneously. Both MATLAB and Simulink software can access components in different languages at any level.

### **HDL Cosimulation Workflows**

The HDL Verifier User Guide provides instruction for using the verification software with supported HDL simulators for the following workflows:

- Simulating an HDL Component in a MATLAB Test Bench Environment
- Replacing an HDL Component with a MATLAB Component Function
- Simulating an HDL Component in a Simulink Test Bench Environment
- Replacing an HDL Component with a Simulink Algorithm
- · Recording Simulink Signal State Transitions for Post-Processing

### **Product Features and Platform Support**

| Product Feature                                       | Required Products                   | Recommended<br>Products                             | Supported Platforms                      |
|-------------------------------------------------------|-------------------------------------|-----------------------------------------------------|------------------------------------------|
| MATLAB and HDL simulator cosimulation (function)      | MATLAB                              | Fixed-Point Designer™, Signal Processing Toolbox™   | Windows® 32- and 64-bit; Linux® 64-bit   |
| MATLAB and HDL simulator cosimulation (System object) | MATLAB and Fixed-<br>Point Designer | Communications<br>Toolbox™, DSP<br>System Toolbox™  | Windows 32- and 64-<br>bit; Linux 64-bit |
| Simulink and HDL simulator cosimulation               | Simulink, Fixed-Point<br>Designer   | Signal Processing<br>Toolbox, DSP System<br>Toolbox | Windows 32- and 64-<br>bit; Linux 64-bit |

### **FPGA Verification**

#### In this section...

"FPGA Verification with HDL Verifier and HDL Coder" on page 2-8

"Product Features and Platform Support" on page 2-9

### FPGA Verification with HDL Verifier and HDL Coder

HDL Verifier works with Simulink or MATLAB and HDL Coder and the supported FPGA development environment to prepare your automatically generated HDL code for implementation in an FPGA. FPGA-in-the-Loop (FIL) simulation allows you to run a Simulink or MATLAB simulation with an FPGA board strictly synchronized with this software. This process lets you get real world data into your design while accelerating your simulation with the speed of an FPGA.

You can generate a FIL programming file in one of the following ways:

- With the HDL Verifier FIL Wizard.
- With the HDL Coder Workflow Advisor.

The FIL Wizard uses any synthesizable HDL code including code automatically generated from Simulink models by HDL Coder software. When you use FIL in the Workflow Advisor, HDL Coder uses the loaded design to create the HDL code. Either way, this HDL code is then augmented by customized code for FIL communication with your design and assembled into an FPGA project. The applicable downstream tools are used to process that project to create a programming file that is automatically downloaded to the FPGA device on a development board for verification.

HDL Verifier supports the use of a FIL block in a model reference block and a System object in conjunction with a MATLAB program.

### **Product Features and Platform Support**

| Product Feature  | Required Products                                                                                                                                  | Recommended<br>Products | Supported Platforms             |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|---------------------------------|
| FPGA-in-the-Loop | For FIL simulation<br>with MATLAB:<br>MATLAB, Fixed-Point<br>Designer<br>For FIL simulation<br>with Simulink:<br>Simulink, Fixed-Point<br>Designer |                         | Windows 64-bit;<br>Linux 64-bit |

### Preregistered FPGA Devices for FIL Simulation

HDL Verifier supports FIL simulation on the devices as described in "Supported FPGA Devices for FPGA Verification" on page 3-6. The FPGA board support packages contain the definition files for all supported boards. You may download one or more vendor-specific packages, but you must download one of the packages before you can use FIL or customize your own board definition file using the New FPGA Board Wizard (see "Create Custom FPGA Board Definition").

To see the list of HDL Verifier support packages, visit "HDL Verifier Supported Hardware" on page 2-15. To download an FPGA board support package:

• On the MATLAB **Home** tab, in the **Environment** section, click **Add-Ons > Get Hardware Support Packages**.

### **TLM Component Generation**

#### In this section...

"Generating TLM Components for Virtual Platform Development" on page 2-10

"Typical Users and Applications" on page 2-11

"Product Feature and Platform Support" on page 2-12

# **Generating TLM Components for Virtual Platform Development**

HDL Verifier lets you create a SystemC Transaction Level Model (TLM) that can be executed in any OSCI-compatible TLM 2.0 environment, including a commercial virtual platform.

When used with virtual platforms, HDL Verifier joins two different modeling environments: Simulink for high-level algorithm development and virtual platforms for system architectural modeling. The Simulink modeling typically dispenses with implementation details of the hardware system such as processor and operating system, system initialization, memory subsystems, device configuration and control, and the particular hardware protocols for transferring data both internally and externally.

The virtual platform is a simulation environment that is concerned about the hardware details: it has components that map to hardware devices such as processors, memories, and peripherals, and a means to model the hardware interconnect between them.

Although many goals could be met with a virtual platform model, the ideal scenario for virtual platforms is to allow for software development—both high level application software and low-level device driver software—by having fairly abstract models for the hardware interconnect that allow the virtual platform to run at near real-time speeds, as demonstrated in the following diagram.



The functional model provides a sort of halfway point between the speed you can achieve with abstraction and the accuracy you get with implementation.

### **Typical Users and Applications**

Using HDL Verifier and Simulink, you can create a TLM-compliant SystemC Transaction Level Model (TLM) that can be executed in any OSCI-compatible TLM environment, including a commercial virtual platform.

Typical users and applications include:

- System-level engineers designing electronic system models that include architectural characteristics
- Software developers who want to incorporate an algorithm into a virtual platform without using an instruction set simulator (ISS).
- Hardware functional verification engineers. In this case, the algorithm represents a piece of hardware going into a chip.

### **Product Feature and Platform Support**

| Product Feature | Required Products | Supported Platforms                        |
|-----------------|-------------------|--------------------------------------------|
| TLM Generator   |                   | Windows 32-bit and<br>64-bit; Linux 64-bit |

### SystemVerilog DPI Component Generation

#### In this section...

"Export Simulink Subsystem or MATLAB Function Using DPI Interface" on page 2-13 "Generate SystemVerilog DPI Test Bench in HDL Coder" on page 2-13

# Export Simulink Subsystem or MATLAB Function Using DPI Interface

You can export a Simulink subsystem or MATLAB function with a DPI interface for Verilog or SystemVerilog simulation. The coder wraps generated C code with a DPI wrapper accessed through a SystemVerilog thin interface function.

- Simulink subsystem Access this feature from the Model Configuration Parameters dialog box, under Code Generation. See "Generate SystemVerilog DPI Component".
- MATLAB function Generate the component using the dpigen function. See "Generate DPI Component Using MATLAB".

HDL Verifier supports SystemVerilog DPI component generation with these products and platforms.

| Design Format      | Required Products              | Recommended<br>Products | Supported Platforms         |
|--------------------|--------------------------------|-------------------------|-----------------------------|
| Simulink subsystem | Simulink and<br>Simulink Coder | Embedded Coder          | • Windows 32-bit and 64-bit |
|                    |                                |                         | • Linux 64-bit              |
| MATLAB function    | MATLAB and                     |                         | • Windows 64-bit            |
|                    | MATLAB Coder                   |                         | • Linux 64-bit              |

### Generate SystemVerilog DPI Test Bench in HDL Coder

If you have an HDL Coder license, you can generate a SystemVerilog DPI test bench. Use the test bench to verify your generated HDL code using C code generated from your entire Simulink model, including the DUT and data sources. To use this feature, your entire model must support C code generation with Simulink Coder. You can access this feature in HDL Workflow Advisor under **HDL Code Generation** > **Set Testbench** 

**Options**, or in the Model Configuration Parameters dialog box, under **HDL Code Generation>Test Bench**. Or, for command-line access, set the GenerateSVDPITestBench property of makehdltb. See "" (HDL Coder).

HDL Verifier supports SystemVerilog DPI test bench generation in HDL Coder with these products and platforms.

| Design Format      | Required Products              | Recommended<br>Products | Supported Platforms         |
|--------------------|--------------------------------|-------------------------|-----------------------------|
| Simulink subsystem | Simulink and<br>Simulink Coder | Embedded Coder          | • Windows 32-bit and 64-bit |
|                    |                                |                         | • Linux 64-bit              |

### See Also

### **More About**

- "DPI Component Generation with Simulink"
- "DPI Component Generation with MATLAB"

### **HDL Verifier Supported Hardware**



As of this release, HDL Verifier supports the following hardware.

| Support Package       | Vendor    |        | Last Release<br>Available |
|-----------------------|-----------|--------|---------------------------|
| Intel FPGA Boards     | Intel     | R2013a | Current                   |
| Microsemi FPGA Boards | Microsemi | R2018a | Current                   |
| Xilinx FPGA Boards    | Xilinx    | R2013a | Current                   |

For a complete list of supported hardware, see Hardware Support.

# **Third-Party Product Requirements**

### **Supported EDA Tools and Hardware**

#### In this section...

"Cosimulation Requirements" on page 3-2

"FPGA Verification Requirements" on page 3-3

"DPI Component Generation Requirements" on page 3-12

"TLM Generation Requirements" on page 3-13

### **Cosimulation Requirements**

- "Cadence Incisive and Xcelium Requirements" on page 3-2
- "Mentor Graphics Questa and ModelSim Usage Requirements" on page 3-3

To get started, see "Set Up MATLAB-HDL Simulator Connection" or "Start HDL Simulator for Cosimulation in Simulink".

### **Cadence Incisive and Xcelium Requirements**

MATLAB and Simulink support Cadence verification tools using HDL Verifier. Only the 64-bit version of Incisive is supported for cosimulation. Use one of these recommended versions, which have been fully tested against the current release:

- Xcelium 18.03
- Xcelium 17.0
- Incisive 15.2

**Note** Not supported for nclaunch with runmode set to Batch. Set runmode to CLI instead.

The HDL Verifier shared libraries (liblfihdls\*.so, liblfihdlc\*.so) are built using the gcc included in the Cadence Incisive simulator platform distribution. Before you link your own applications into the HDL simulator, first try building against this gcc. See the HDL simulator documentation for more details about how to build and link your own applications.

### Mentor Graphics Questa and ModelSim Usage Requirements

MATLAB and Simulink support Mentor Graphics verification tools using HDL Verifier. Use one of the following recommended versions. Each version has been fully tested against the current release:

- Questa Core/Prime 10.5b, 10.6b
- QuestaSim 10.4c
- ModelSim PE 10.4c, 10.6b

### **FPGA Verification Requirements**

- "Xilinx Usage Requirements" on page 3-3
- "Intel Quartus Usage Requirements" on page 3-3
- "Microsemi Usage Requirements" on page 3-4
- "Supported FPGA Board Connections for FIL Simulation" on page 3-4
- "Supported FPGA Devices for FPGA Verification" on page 3-6
- "Supported FPGA Device Families for Board Customization" on page 3-11

### **Xilinx Usage Requirements**

MATLAB and Simulink support Xilinx design tools using HDL Verifier. Use the FPGA-inthe-loop tools with these recommended versions:

- Xilinx Vivado® 2018.2
- Xilinx ISE 14.7

**Note** Xilinx ISE is required for FPGA boards in the Spartan®-6, Virtex®-4, Virtex-5, and Virtex-6 families.

For tool setup instructions, see "Set Up FPGA Design Software Tools".

### **Intel Quartus Usage Requirements**

MATLAB and Simulink support Intel design tools using HDL Verifier. Use the FPGA-in-the-loop tools with these recommended versions:

• Intel Quartus® Prime 18.0

- Intel Quartus Prime Pro 18.0 (supported for Intel Cyclone® 10 GX only)
- Intel Quartus II 13.1 (supported for Intel Cyclone III boards only)

For tool setup instructions, see "Set Up FPGA Design Software Tools".

### Microsemi Usage Requirements

MATLAB and Simulink support Microsemi design tools using HDL Verifier. Use the FPGA-in-the-loop tools with these recommended versions:

- Microsemi Libero<sup>®</sup> SoC 11.8 SP3
- Microsemi Libero SoC Polarfire® 2.0

For tool setup instructions, see "Set Up FPGA Design Software Tools".

### **Supported FPGA Board Connections for FIL Simulation**

For board support, see "Supported FPGA Devices for FPGA Verification" on page 3-6.

Additional boards can be custom added with the "FPGA Board Manager". See "Supported FPGA Device Families for Board Customization" on page 3-11.

#### JTAG Connection

| Vendor | Required Hardware                                    | Required Software                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------|------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Intel  | USB Blaster I or USB<br>Blaster II download<br>cable | <ul> <li>USB Blaster I or II driver</li> <li>For Windows operating systems: Quartus Prime executable directory must be on system path.</li> <li>For Linux operating systems: versions below Quartus II 13.1 are not supported. Quartus II 14.1 is not supported. Only 64-bit Quartus is supported. Quartus library directory must be on LD_LIBRARY_PATH before starting MATLAB. Prepend the Linux distribution library path before the Quartus library on LD_LIBRARY_PATH. For example, /lib/x86 64-linux-gnu:\$QUARTUS PATH.</li> </ul> |

| Vendor | Required Hardware                                                                                                                                                                                                    | Required Software                                                                                                                                                   |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Xilinx | Digilent® download cable.  • If your board has an onboard Digilent USB-JTAG module, use a USB cable.  • If your board has a standard Xilinx 14 pin JTAG connector, you can obtain an HS2 or HS3 cable from Digilent. | <ul> <li>For Windows operating systems: Xilinx Vivado executable directory must be on system path.</li> <li>For Linux operating systems: Digilent Adept2</li> </ul> |
|        | • Supported for boards with onboard FT4232H or FT2232H devices, implementing USB-to JTAG                                                                                                                             | Note FTDI USB JTAG support is only available for MATLAB as AXI Master and for FPGA Data Capture.                                                                    |

**Note** When simulating your FPGA design through Digilent JTAG cable with Simulink or MATLAB, you cannot use any debugging software that requires access to the JTAG; for example, Vivado Logic Analyzer.

#### **Ethernet Connection**

| Required Hardware                                   | Supported Interfaces       | Required Software                                                        |
|-----------------------------------------------------|----------------------------|--------------------------------------------------------------------------|
| Gigabit Ethernet card                               | Gigabit Ethernet — GMII    | There are no software                                                    |
| Cross-over Ethernet cable                           | • Gigabit Ethernet — RGMII | requirements for an Ethernet connection, but ensure that the firewall on |
| FPGA board with<br>supported Ethernet<br>connection | • Gigabit Ethernet — SGMII | the host computer does not prevent UDP                                   |
| Connection                                          | • Ethernet — MII           | communication.                                                           |
|                                                     | Note The HDL Verifier      | <b>Note</b> Ethernet connection                                          |
|                                                     | Support Package for        | to Virtex-7 VC707 not                                                    |
|                                                     | Microsemi FPGA Boards      | supported for Vivado                                                     |
|                                                     | supports only SGMII        | versions older than 2013.4.                                              |
|                                                     | interfaces.                |                                                                          |

### **Supported FPGA Devices for FPGA Verification**

HDL Verifier supports FIL simulation on the devices shown in the following table. The board definition files for these boards are in the "Download FPGA Board Support Package". You can add other FPGA boards for use with FIL with FPGA board customization ("FPGA Board Customization").

**Note** FIL over PCI Express® connection is supported only for 64-bit Windows operating systems.

| Device<br>Family    | Board                       | Ether<br>net | JTAG | PCI<br>Expre<br>ss | Comments |
|---------------------|-----------------------------|--------------|------|--------------------|----------|
| Xilinx<br>Artix®-7  | Digilent Nexys™4<br>Artix-7 | X            | X    |                    |          |
|                     | Digilent Arty Board         |              | x    |                    |          |
| Xilinx<br>Kintex®-7 | Kintex-7 KC705              | X            | X    | X                  |          |

| Device<br>Family                     | Board                                               | Ether<br>net | JTAG | PCI<br>Expre<br>ss | Comments                               |
|--------------------------------------|-----------------------------------------------------|--------------|------|--------------------|----------------------------------------|
| Xilinx<br>Kintex<br>UltraScale<br>™  | Kintex UltraScale<br>FPGA KCU105<br>Evaluation Kit  | X            | x    |                    |                                        |
| Xilinx<br>Kintex<br>UltraScale<br>+™ |                                                     |              | X    |                    | Supported for board customization only |
| Xilinx                               | Spartan-6 SP605                                     | X            |      |                    |                                        |
| Spartan-6                            | Spartan-6 SP601                                     | X            |      |                    |                                        |
|                                      | XUP Atlys Spartan-6                                 | X            |      |                    |                                        |
| Xilinx<br>Spartan-7                  | Digilent Arty S7-25                                 | X            | X    |                    |                                        |
| Xilinx<br>Virtex<br>UltraScale       | Virtex UltraScale<br>FPGA VCU108<br>Evaluation Kit  | X            | X    |                    |                                        |
| Xilinx<br>Virtex<br>UltraScale<br>+  | Virtex UltraScale+<br>FPGA VCU118<br>Evaluation Kit |              | X    | x                  |                                        |
| Xilinx                               | Virtex-7 VC707                                      | X            | X    | x                  |                                        |
| Virtex-7                             | Virtex-7 VC709                                      |              | X    | x                  |                                        |
| Xilinx<br>Virtex-6                   | Virtex-6 ML605                                      | X            |      |                    |                                        |
| Xilinx                               | Virtex ML505                                        | X            |      |                    |                                        |
| Virtex-5                             | Virtex ML506                                        | X            |      |                    |                                        |
|                                      | Virtex ML507                                        | X            |      |                    |                                        |
|                                      | Virtex XUPV5-LX110T                                 | X            |      |                    |                                        |

| Device<br>Family                  | Board                                              | Ether<br>net | JTAG | PCI<br>Expre<br>ss | Comments                                                                                                      |
|-----------------------------------|----------------------------------------------------|--------------|------|--------------------|---------------------------------------------------------------------------------------------------------------|
| XilinxVirte                       | Virtex ML401                                       | x            |      |                    | Note Support for Virtex-4                                                                                     |
| x-4                               | Virtex ML402                                       | x            |      |                    | device family will be removed in a future release.                                                            |
|                                   | Virtex ML403                                       | x            |      |                    | in a future release.                                                                                          |
| Xilinx                            | Zynq-7000 ZC702                                    |              | X    |                    |                                                                                                               |
| Zynq®                             | Zynq-7000 ZC706                                    |              | X    |                    |                                                                                                               |
|                                   | ZedBoard™                                          |              | X    |                    | Use the USB port marked "PROG" for programming.                                                               |
|                                   | ZYBO™ Zynq-7000<br>Development Board               |              | X    |                    |                                                                                                               |
|                                   | PicoZed™ SDR<br>Development Kit                    |              | X    |                    |                                                                                                               |
| Xilinx<br>Zynq<br>UltraScale<br>+ | Zynq UltraScale+<br>MPSoC ZCU102<br>Evaluation Kit |              | X    |                    |                                                                                                               |
| Intel<br>Arria® II                | Arria II GX FPGA<br>Development Kit                | X            | X    |                    |                                                                                                               |
| Intel Arria<br>V                  | Arria V SoC<br>Development Kit                     |              | X    |                    |                                                                                                               |
|                                   | Arria V Starter Kit                                | x            | X    |                    |                                                                                                               |
| Intel Arria<br>10                 | Arria 10 SoC<br>Development Kit                    | X            | X    |                    |                                                                                                               |
|                                   | Arria 10 GX                                        | X            | х    | X                  | Note Use Quartus Prime<br>17.1 for Arria 10 GX over PCI<br>Express. Quartus Prime 18.0<br>is not recommended. |
| Intel<br>Cyclone<br>IV            | Cyclone IV GX FPGA<br>Development Kit              | X            | X    |                    |                                                                                                               |

| Device<br>Family          | Board                                                             | Ether<br>net | JTAG | PCI<br>Expre<br>ss | Comments                                                                                                                                                                                                                  |  |
|---------------------------|-------------------------------------------------------------------|--------------|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                           | DE2-115 Development<br>and Education Board                        | X            | x    |                    | The Altera® DE2-115 FPGA development board has two Ethernet ports. FPGA-in-the-loop uses only Ethernet 0 port. Make sure that you connect your host computer with the Ethernet 0 port on the board via an Ethernet cable. |  |
|                           | BeMicro SDK                                                       | X            | X    |                    |                                                                                                                                                                                                                           |  |
| Intel<br>Cyclone          | Cyclone III FPGA<br>Starter Kit                                   |              | X    |                    | Altera Cyclone III boards are supported with Quartus II                                                                                                                                                                   |  |
| III                       | Cyclone III FPGA<br>Development Kit                               | X            | X    |                    | 13.1                                                                                                                                                                                                                      |  |
|                           | Altera Nios II<br>Embedded Evaluation<br>Kit, Cyclone III Edition | X            | X    |                    | <b>Note</b> Support for Cyclone III device family will be removed in a future release.                                                                                                                                    |  |
| Intel<br>Cyclone V        | Cyclone V GX FPGA<br>Development Kit                              | X            | X    |                    |                                                                                                                                                                                                                           |  |
|                           | Cyclone V SoC<br>Development Kit                                  |              | X    |                    |                                                                                                                                                                                                                           |  |
|                           | Cyclone V GT<br>Development Kit                                   | X            | X    | X                  |                                                                                                                                                                                                                           |  |
|                           | Terasic Atlas-SoC Kit /<br>DE0-Nano SoC Kit                       |              | X    |                    |                                                                                                                                                                                                                           |  |
|                           | Arrow <sup>®</sup> SoCKit<br>Development Kit                      |              | X    |                    |                                                                                                                                                                                                                           |  |
| Intel<br>Cyclone<br>10 LP | Altera Cyclone 10 LP<br>Evaluation Kit                            |              | X    |                    |                                                                                                                                                                                                                           |  |

| Device<br>Family          | Board                                                             | Ether<br>net | JTAG | PCI<br>Expre<br>ss | Comments                                                                                                |
|---------------------------|-------------------------------------------------------------------|--------------|------|--------------------|---------------------------------------------------------------------------------------------------------|
| Intel<br>Cyclone<br>10 GX | Altera Cyclone 10 GX<br>FPGA Evaluation Kit                       |              | X    |                    | Must be used with Quartus<br>Prime Pro                                                                  |
| Intel<br>MAX® 10          | Arrow MAX 10 DECA                                                 | X            | X    |                    |                                                                                                         |
| Intel<br>Stratix®<br>IV   | Stratix IV GX FPGA<br>Development Kit                             | X            | x    |                    |                                                                                                         |
| Intel<br>Stratix V        | DSP Development Kit,<br>Stratix V Edition                         | X            | X    | X                  |                                                                                                         |
|                           | Microsemi<br>SmartFusion2 SoC<br>FPGA Advanced<br>Development Kit | X            |      |                    | See "Supported Microsemi<br>FPGA Boards" (HDL Verifier<br>Support Package for<br>Microsemi FPGA Boards) |
| Microsemi<br>Polarfire    | Microsemi Polarfire<br>Evaluation Kit                             | X            |      |                    | See "Supported Microsemi<br>FPGA Boards" (HDL Verifier<br>Support Package for<br>Microsemi FPGA Boards) |
| Microsemi<br>RTG4®        | RTG4-DEV-KIT                                                      | X            |      |                    |                                                                                                         |

#### Limitations

For FPGA development boards that have more than one FPGA device, only one such
device can be used with FIL.

### **FPGA Board Support Packages**

The FPGA board support packages contain the definition files for all supported boards. You can download one or more vendor-specific packages. To use FIL, download at least one of these packages, or customize your own board definition file. See "Create Custom FPGA Board Definition".

To see the list of HDL Verifier support packages, visit "HDL Verifier Supported Hardware" on page 2-15. To download an FPGA board support package:

• On the MATLAB **Home** tab, in the **Environment** section, click **Add-Ons > Get Hardware Support Packages**.

### **Supported FPGA Device Families for Board Customization**

HDL Verifier supports the following FPGA device families for board customization; that is, when you create your own board definition file. See "FPGA Board Customization". PCI Express is not a supported connection for board customization.

**Note** The HDL Verifier Support Package for Microsemi FPGA Boards does not support board customization.

| <b>Device Family</b> | 1                  | Restrictions                                                                        |
|----------------------|--------------------|-------------------------------------------------------------------------------------|
| Xilinx               | Artix 7            |                                                                                     |
|                      | Kintex 7           |                                                                                     |
|                      | Kintex UltraScale  |                                                                                     |
|                      | Kintex UltraScale+ |                                                                                     |
|                      | Spartan 6          | Ethernet PHY RGMII is not supported.                                                |
|                      | Spartan 7          |                                                                                     |
|                      | Virtex 4           | <b>Note</b> Support for Virtex-4 device family will be removed in a future release. |
|                      | Virtex 5           |                                                                                     |
|                      | Virtex 6           |                                                                                     |
|                      | Virtex 7           | Supports Ethernet PHY SGMII only.                                                   |
|                      | Virtex UltraScale  |                                                                                     |
|                      | Virtex UltraScale+ |                                                                                     |
|                      | Zynq 7000          |                                                                                     |
|                      | Zynq UltraScale+   |                                                                                     |
| Intel                | Arria II           |                                                                                     |

| <b>Device Family</b> |               | Restrictions                                                                           |
|----------------------|---------------|----------------------------------------------------------------------------------------|
|                      | Arria V       |                                                                                        |
|                      | Arria 10      |                                                                                        |
|                      | Cyclone III   | <b>Note</b> Support for Cyclone III device family will be removed in a future release. |
|                      | Cyclone IV    |                                                                                        |
|                      | Cyclone V     |                                                                                        |
|                      | Cyclone 10 LP |                                                                                        |
|                      | Cyclone 10 GX |                                                                                        |
|                      | MAX 10        |                                                                                        |
|                      | Stratix IV    |                                                                                        |
|                      | Stratix V     |                                                                                        |

### **DPI Component Generation Requirements**

DPI component generation supports the same versions of Cadence Incisive and Mentor Graphics Questa and ModelSim as for cosimulation. You can generate a DPI component for use with either 64-bit or 32-bit Incisive.

In addition, DPI Component generation also supports:

• Synopsys VCS® MX N-2017.12 SP2

**Note** When you run a DPI component in ModelSim 10.5b on Debian<sup>®</sup> 8.3, you may encounter a library incompatibility error:

```
** Warning: ** Warning: (vsim-7032) The 64-bit glibc RPM does not appear to be installed on this machine. Calls to gcc may fail. 
** Fatal: ** Error: (vsim-3827) Could not compile 'STUB_SYMS_OF_fooour.so':
```

To avoid this issue, on the **Code Generation** pane in Configuration Parameters, try these options:

- Set the Build configuration to Faster Runs.
- Or, set the **Build configuration** to Specify and specify the compiler flag -03.

### **TLM Generation Requirements**

With the current release, TLMG includes support for:

- · Compilers:
  - Visual Studio<sup>®</sup>: VS2008, VS2010, VS2012, VS2013 and VS2015
  - Windows 7.1 SDK
  - gcc 6.3
- SystemC:
  - SystemC 2.3.1 (TLM included)

You can download SystemC and TLM libraries at https://accellera.org. Consult the Accellera Systems Initiative website for information about how to build these libraries after downloading.

- System C Modeling Library (SCML):
  - SCML 2.2

You can download SCML from https://www.synopsys.com.